Attorney's Docket No.: 3997P008 



Patent 



United States Patent Application 

For 

Method for Dynamical Identification of Network Congestion 

Characteristics 



Inventors: 

Gilbert Grosdidier 
Han C. Wen 
Ian Adam 
Minh Duong-van 
Tomas J. Pavel 
Richard Blankenbecler 

Prepared by: 

BLAKELY, SOKOLOFF, TAYLOR & ZAFMAN LLP 
12400 WILSHIRE BOULEVARD 

SEVENTH FLOOR 
LOS ANGELES, CA 90025-1026 

(408) 720-8300 



"Express Mail" mailing label number: EL617184066US 

Date of Deposit: April 30, 2001 

I hereby certify that I am causing this paper or fee to be deposited with the 
United States Postal Service "Express Mail Post Office to Addressee" 
service on the date indicated above and that this paper or fee has been 
addressed to the Assistant Commissioner for Patents, Washington, D. C. 20231 

Patricia A. Balero 

CTyped or printed name of person mailing paper or fee) 

ng^Qtyea 

(Signature of person mailing paper or fee) 



Method for Dynamical Identification of Network Congestion 

Characteristics 



Field of the Invention 

[0001] The present invention relates to a scheme for identifying the presence or absence 
of congestion in the network and categorizing such congestion, when present. 

Background 

[0002] Many communication networks, such as the Internet, rely on packet switching 
technologies (e.g., X.25, frame relay, asynchronous transfer mode, etc.) to transport variable 
or uniform blocks (usually termed packets or cells) of data between nodes. The term packet 
will be used herein to collectively refer to any such block of information. Such networks 
generally perform two major functions: routing and congestion control. The object of routing 
is to deliver, correctly and sometimes in sequence, the packets from a source to a destination. 
The object of congestion control is to maintain the number of packets within the network (or 
a region or sub-network thereof) below a level at which queuing delays become excessive. 
Due to finite resources, packets may be dropped rather than queued. 
[0003] In essence, a packet switched network is a network of queues communicatively 
coupled together by communication links (which may be made up of various physical 
media). At each network node (e.g., a switch or router), there exist one or more queues of 
packets for each outgoing link. If the rate at which packets arrive and queue up exceeds the 
rate at which packets are transmitted, queue size grows without bound and the delay 
experienced by a packet tends towards infinity. In such situations, the network is said to be 
congested. 
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[0004] In an ideal case, network throughput, and hence network use, should increase to 
an offered load up to the physical capacity of the network and remain at capacity if the load is 
further increased. This ideal case, however, requires that all nodes somehow know the 
timing and rate of packets that will be presented to the network with no overload and no 
delay in acquiring this information; a situation which is not possible. If no congestion 
control is exercised, as the load increases, use increases for a while. Then, as the queue 
lengths at various nodes begin to grow, throughput actually drops. This is due to the fact that 
the queues are constrained to a finite length by the physical size of the memories in which 
they exist. When a node's memory (i.e., its queues) is full, it must drop (i.e., discard) 
additional incoming packets. Thus, the source is forced to retransmit these packets in 
addition to any new packets it might have. This only serves to worsen the situation. As more 
and more packets are retransmitted, the load on the network grows and more and more nodes 
become saturated. Eventually, even a successfully delivered packet may be retransmitted 
because it takes so long to get to its destination (whereupon it may be acknowledged by the 
destination node) that the source actually assumes that the packet was lost and tries to 
retransmit it. Under such circumstances, the effective capacity of the network can be 
virtually zero. 

[0005] Contrary to what one might believe, the solution to this problem is not simply to 
allow the queue lengths to grow indefinitely. Indeed, it has been shown that even where 
queue lengths are allowed to be infinite, congestion can occur. See, e.g., John Nagle, "On 
Packet Switches with Infinite Storage", Network Working Group, Internet Engineering Task 
Force, RFC 970 (1985). One reason that this is true is that packets are often coded with an 
upper bound on their life, thus causing expired packets to be dropped and retransmitted, 
adding to the already overwhelming volume of traffic within the network. 
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[0006] Very early in the development of the modern Internet, it was discovered that some 
control over the manner in which packets were injected into the network by the source was 
needed to help with the problem of dropped packets. Originally, the well-known 
transmission control protocol (TCP) allowed a source to inject multiple packets into a 
network, up to a limit corresponding to a window or buffer size advertised by the receiver. 
Although such a scheme may work where the source and the receiver are connected to the 
same local area network, it was soon found that where routers having finite buffer sizes are 
disposed between the source and the receiver, problems arise as these routers soon run out of 
space to hold the incoming packets. To combat this problem Jacobson and Karels developed 
a "slow start" procedure wherein the source limits the rate at which it injects new packets into 
the network according to the rate at which acknowledgements of successful receptions are 
returned by the receiver. Van Jacobson and Michael J. Karels, "Congestion Avoidance and 
Control", Proceedings of SIGCOMM '88 (Stanford, CA, Aug. 1988), ACM. 
[0007] Under the slow start procedure, a so-called congestion window is added to the 
source's TCP implementation. When a connection is established with a resource on another 
network, this congestion window is initialized to one segment (e.g., the segment or packet 
size advertised by the resource or a default packet size). Each time an acknowledgement is 
received, the congestion window is incremented and the source is allowed to inject a number 
of packets up to the minimum of the current congestion window size or the receiver's 
advertised window. Over time, the source's congestion window will grow exponentially until 
at some point the capacity of the intervening network is reached and some intermediate router 
begins dropping packets. This is an indication to the source that its congestion window has 
gotten too large. See, e.g., W. Richard Stevens, TCP/IP Illustrated, Vol, 1: The Protocols 
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(1994) and Gary W. Wright and W. Richard Stevens, TCP/IP Illustrated, Vol. 2: The 
Implementation (1995). 

[0008] At this point, and where the slow start process is run in concert with a 
conventional congestion avoidance procedure, the source resets its congestion window to 
one, and the process repeats up to the point at which the congestion window becomes half the 
size at which packet loss occurred previously. After this point, the congestion avoidance 
process takes over and begins incrementing the congestion window in a linear fashion (rather 
than in an exponential fashion as under the slow start process) in response to receiver 
acknowledgements. 

[0009] Even with the slow-start process, however, congestion occurs within packet 
switched networks. Some of the present applicants have proposed certain congestion control 
methods in a number of co-pending patent applications. For example, in co-pending 
Application No. , entitled "METHOD FOR ACCELERATING TCP FLOWS IN 

Communication Networks with Dynamic Control", filed , and assigned to 

the assignee of the present application, a scheme for controlling congestion wherein 
predictions of congestion conditions for a traffic stream in a communication network are 
applied to modify an initial congestion window size for the traffic stream; and dynamic 
bandwidth control is thereafter applied to the traffic stream was proposed. In one 
embodiment (which itself was based on a congestion control technique described in co- 
pending Application No. 09/539,434, entitled "METHOD FOR REDUCING PACKET LOSS AND 
Increasing Internet Flow by Feedback Control," filed March 30, 2000 and assigned 
to the assignee of the present application) this dynamic bandwidth control included 
modulating inter-packet bandwidths of the traffic stream according to a capacity of a 
bottleneck in a communication path through which the traffic stream passes in the 
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communication network. The predictions of congestion conditions may be based on 
monitoring packet losses within the communication network. The monitoring may be 
performed on at least one of a traffic stream-by traffic stream basis, a connection-by- 
connection basis, a link-by-link basis, or a destination-by-destination basis. Further, the 
monitoring may performed for a period between 0 and 100 seconds. 
[0010] In some cases, the control techniques discussed in these co-pending applications, 
as well as other congestion control techniques developed by the present applicants, proved 
even better performance when the type of congestion being experienced can be determined. 
It is the procedures for making such determinations that are the subject of this application. 
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Summary of the Invention 

[0011] In one embodiment, congestion within a traffic stream of interest in a 
communication network is characterized as self-induced congestion or cross-induced 
congestion by analyzing a correlation result of a time series of throughput data of the traffic 
stream of interest and making the characterization based on power spectrum features found in 
the correlation result. The correlation result may be obtained through a Fourier analysis, a 
wavelet analysis or any mathematical process based on locating periodicities in the time 
series. In some cases, the characterization is made at a node in the communication network 
that is downstream from the congestion, while in other cases the characterization is made at a 
node in the communication network that is upstream of the congestion. 
[0012] The power spectrum features may include one or more of a distinctive peak within 
the power spectrum and area content of the power spectrum at low frequencies. The 
congestion is characterized as self-induced when the power spectrum exhibits one or more 
well-defined peaks and little energy at low frequencies. Alternatively, the congestion is 
characterized as cross-induced when the power spectrum does not exhibit well-defined peaks 
and has relatively high power at low frequencies. 

[0013] In another embodiment, a communication network includes one or more nodes at 
which traffic streams are buffered and at least one monitor node coupled in a communication 
path with one of the nodes at which traffic streams are buffered. The monitor node is 
configured to take a sample of throughput data for a traffic stream of interest, to compute a 
correlation result for the sample, and to determine whether congestion exists along the 
communication path of the traffic stream of interest according to whether or not certain 
features are found in the correlation result. The correlation result may be obtained through a 
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Fourier analysis, a wavelet analysis or any mathematical process based on locating 
periodicities in the time series. 

[0014] Preferably, the monitor node is configured to determine that self-induced 
congestion exists along the communication path of the traffic stream of interest if the 
correlation result exhibits one or more well-defined peaks and little power at low frequencies 
in the face of packet loss within the traffic stream of interest and to determine that cross- 
induced congestion exists along the communication path of the traffic stream of interest if the 
correlation result exhibits one or more not well-defined peaks and relatively high power at 
low frequencies in the face of packet loss within the traffic stream of interest. The monitor 
node may be further configured to implement a congestion control process according to 
whether or not cross-induced congestion or self-induced congestion is found in the 
communication path of the traffic stream of interest. Alternatively, a control node may be 
configured to implement the congestion control process according to whether or not cross- 
induced congestion or self-induced congestion is found in the communication path of the 
traffic stream of interest. 

[0015] In yet another embodiment, a sample of throughput data for a traffic stream of 
interest in a communication network is analyzed to produce a power spectrum of the sample 
and the power spectrum is compared to stored replicas of power spectrums of known 
congestion sources within the communication network to determine a source of congestion 
(e.g., a bottleneck) for the traffic stream of interest. In some cases, peaks of the power 
spectrum of the sample are compared to peaks of the stored replicas of the power spectrums 
of the known congestion sources. Further, a congestion control process may be applied to the 
traffic stream of interest based on results of the comparison. The location of these peaks in 
the Fourier power spectrum may reveal the bottleneck capacity as follows: 
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Bottleneck bandwidth = (packet size) / (period), 
where the period is the inverse of the frequency of the peak as determined from the Fourier 
power spectrum. 
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Brief Description of the Drawings 

[0016] The present invention is illustrated by way of example, and not limitation, in the 
figures of the accompanying drawings in which like reference numerals refer to similar 
elements and in which: 

[0017] Figure 1 shows an example of a congested router in a communication network as 
well as a monitor node which can be used to categorize the type of congestion being 
experienced in accordance with an embodiment of the present invention. 
[0018] Figure 2 shows a plot of a Fourier power spectrum of a traffic stream in an 
uncongested network. 

[0019] Figure 3 shows a plot of a Fourier power spectrum of a traffic stream in a 
network experiencing self-induced congestion. 

[0020] Figure 4 shows a plot of a Fourier power spectrum of a traffic stream in a 
network experiencing cross-induced congestion. _ 
[0021] Figure 5 shows the network for which the plot of Figure 2 was obtained. 
[0022] Figure 6 shows the network for which the plot of Figure 3 was obtained. 
[0023] Figure 7 shows the network for which the plot of Figure 4 was obtained. 
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Detailed Description 

[0024] A scheme for categorizing congestion in a computer or communication network, 
such as the Internet or other packet switched network, is disclosed herein. Although 
discussed with reference to certain illustrated embodiments, upon review of this 
specification, those of ordinary skill in the art will recognize that the present scheme may 
find application in a variety of systems. Therefore, in the following description the 
illustrated embodiments should be regarded as exemplary only and should not be deemed to 
be limiting in scope. It should also be noted that as used herein the term "packet" is meant to 

0 broadly refer to packets, cells and other forms of information units used to transport data 

03 and/or control information within communications infrastructures (e.g., computer networks, 

01 telecommunications networks, data communication networks and the like, for example, the 
IJl Internet) wherein resources are shared among multiple users and multiple information or 

s traffic streams. 

[0025] Existing congestion control approaches have generally viewed network traffic 

l : '£ 

(e.g., the generation of new packets to be injected into a network) as essentially random 
r: processes. However, recent work in the area of traffic modeling has shown that network 

traffic is in fact chaotic in nature. None of the currently proposed congestion control 
methodologies capture or exploit this characteristic. 

[0026] Sources of congestion within a network can be understood with reference to 
Figure 1. Shown in this illustration is a router (or other network node, such as a switch, 
bridge, etc.) 10 which is connected in a communication path between a traffic source of 
interest 12 and a client 14. This connection exists through communication links 16 and 18, 
which generally will not have equal bandwidths. That is, some bandwidth mismatch will 
often occur at nodes such as router 10. Often the communication link coupling the network 
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node to the content source (i.e., link 16 in this example) will have a greater bandwidth than 
the communication link coupling the node to a client (i.e., link 18 in this example). 
[0027] Whenever a bandwidth mismatch of this type occurs, some packet buffering will 
be required. Hence, router 10 in equipped with one or more buffers 20, which are configured 
to store packets received from the traffic source until they can be transmitted on to the client 
14. These transmissions usually occur at some periodic interval, usually defined by a 
scheduler in router 10 (not shown). The scheduler allows packet transmissions to take place 
depending upon the bandwidth of the outgoing communication link, customer subscription 
agreements and/or other network conditions. 

[0028] In addition to the traffic of interest, router 10 may also be in the communication 
path for one or more other traffic streams, some of which may be bound for client 14 and 
others of which may be bound for other nodes in or coupled to the network. This cross- 
traffic 22 may exist on one or more communication links 24 and may also involve packets 
being buffered at router 10 for some period of time. 

[0029] As discussed above, congestion will occur at router 10 when buffer 20 (and 
assume for the moment that this buffer represents all available buffers at router 10) is full and 
new packets arrive before old packets can be transmitted out of the buffer. In such a case, 
packets will be dropped. This situation may occur for either of two reasons. First, in cases 
where there is little or no cross-traffic, or stated differently, where all of the traffic seen by 
buffer 20 is traffic of interest, then the packets that are dropped will be packets of the traffic 
stream(s) of interest. This is referred to herein as "self-induced congestion". That is, the 
congestion results primarily (or solely) as a result of traffic from the streams of interest. 
[0030] The second situation involves cases where there would be no congestion but for 
the presence of cross-traffic 22. That is, the buffer overflows (and subsequent packet drops) 
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are a result of heavy cross-traffic. Not only are packets from this cross-traffic dropped, but 
so too are packets from the traffic stream(s) of interest 12 dropped (because all packets must 
use the same buffer(s) 20. This situation is referred to a "cross-induced congestion" to point 
out the fact that it is (primarily) due to cross-traffic 22. 

[0031] The present invention provides a mechanism to distinguish between situations 
when congestion is self-induced form when it is cross-induced. Stated briefly, by analyzing a 
time series of the throughput data of the traffic stream(s) of interest (preferably at very fine 
time scales), and then applying a Fourier (or other periodic, e.g., wavelet) analysis, the 
present applicants have found that congestion "signatures" can be observed and these 
signatures are different for the case of self-induced congestion than for cross-induced 
congestion. As shown in Figure 1, the analysis can be performed at a monitor node 26, 
which is located either upstream of downstream of the congested router 10. 
[0032] Stated differently, for a given congested network route, the underlying 
mechanisms that characterize the congestion can be identified by a time series analysis of one 
or more streams that are transferring files along that network route. In particular, a Fourier 
transform of the time series of the throughput (number of packets transferred per time period) 
of these streams, reveals a signature that identifies the type of congestion occurring along that 
specified network route. Other analyses that a Fourier transform may be performed, for 
example a wavelet transform may be used or any other transform that reveals periodicity in a 
time series of data. 

[0033] An analysis of the time series of the streams monitored traversing a congested 
route can reveal the characteristics of the congestion. Fourier transforming the time series of 
throughput results in a Fourier power spectrum that exhibits strongly identifiable differences 
between congestion that is self-induced versus cross-induced. If the congestion is self- 
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induced, the power spectrum shows strong peaks at frequencies associated with each link 
where significant bandwidth mismatches occur. If the congestion is cross-induced, the 
aforementioned peaks are suppressed in amplitude while broad peaks at much lower 
frequencies emerge. The power spectrum for congestion that is cross-induced is generally 
flatter than for congestion that is self-induced, where the latter shows suppression of Fourier 
power at the lower frequencies. 

[0034] Two underlying mechanisms determine the characteristics of the time series of 
streams with a common network route. 1) The end-to-end dynamics generated by the file-size 
D distribution, the client "think-time" distribution, the round trip times and the aggregation of 

ffl multiple simultaneous streams. All of these factors result in a rich array of resonances, which 

01 translates into a (Type A) power spectrum of multiple peaks, with various harmonics of 

yi differing heights and widths. Such a spectrum is illustrated in the plot of Figure 2. 2) The 

~ local dynamics generated by the queuing discipline performed by the routers along the route 

j» where congestion occurs. Congestion is a product of both bandwidth mismatch and load. 

% When the queue fills, the dynamics of packets scheduled to leave reduces to a relatively 

WET 
™^ 

rf simple "leaky-bucket" scenario; a single rate, that of the congested link, of one packet every 

MTU/BW. MTU is the maximum transmission unit and BW is the physical bandwidth of the 
congested link. This translates into a "leaky-bucket" peak in the Fourier spectrum for each 
bandwidth mismatch at frequencies corresponding to l/("leaky bucket" rate) = MTU/BW. 
The location of these peaks in the Fourier power spectrum may reveal the bottleneck capacity 
as follows: 

Bottleneck bandwidth = (packet size) / (period), 
where the period is the inverse of the frequency of the peak as determined from the Fourier 
power spectrum. 
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[0035] If the queue is continuously saturated due to heavy loads, the "leaky-bucket" 
dynamics filters out much of the time variability introduced by the end-to-end dynamics. 
This translates into a power spectrum that in contrast to Type A, has most of the finer peaks 
washed out, while having the "leaky bucket" peaks enhanced (Type B, see Figure 3) if the 
congestion is self-induced congestion or suppressed (Type C, see Figure 4) if the congestion 
is cross-induced. 

[0036] The presence of cross-induced congestion imposes a different aspect of local 
dynamics on the monitored streams than that of self-induced congestion. When there is 
cross-induced congestion, the "leaky bucket" dynamics of the cross-traffic drives not only its 
own traffic, but also the monitored streams traffic, albeit at a muted level. The cross-traffic 
also induces low frequency oscillations in the monitored streams traffic that are not present in 
the cross-traffic's own power spectrum. 

[0037] Given the two mechanisms of end-to-end and local dynamics as described above, 
the implications for identifying the congestion type become straightforward. If there is 
congestion with significant packet loss and the power spectrum exhibits strong peaks at high 
frequencies with relatively little power at low frequencies, then the congestion is self-induced 
by the monitored streams. If instead, the power spectrum is relatively flat with power and 
broad resonances at both high and low frequencies, then the congestion is induced by cross- 
traffic through one or more router nodes along the route. 

[0038] Figure 2 shows an example of a Fourier power spectrum plotted versus 
1/frequency (i.e., period) that is predominately Type A (rich spectrum of peaks at all 
frequencies) with some evidence of Type B congestion (peaks at frequencies corresponding 
to the 45Mbps to 1.5Mbps bandwidth mismatch (-8ms) and the 100Mbps to 45Mbps 
bandwidth mismatch (<2ms)). Packet Loss is less than 1 percent. Figure 5 illustrates the 
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network 28 for which this plot was obtained. The buffer size (Buf) for each node 30 (which 
may be a router, for example) is shown, as are the bandwidths for the communication links 
32, 34 and 36. 

[0039] Figure 3 shows an example of a Fourier power spectrum plotted versus 
1/frequency = period that is purely Type B congestion. Notice the strong peaks at the 
bandwidth mismatches and the suppression of power at large periods. Packet loss is 
approximately 13 percent. In this example, the strong peak occurs at a period of 
approximately 8 msec. This corresponds to the bottleneck bandwidth of 1.5 Mbits/sec 
(assuming a packet size of 1500 bytes) (BW = packet size/period=1500 bytes/8msec - 1.5 
Mbits/sec). Figure 6 illustrates the conditions for network 28 for which this plot was 
obtained. 

[0040] Figure 4 shows an example of a Fourier power spectrum plotted versus 
1/frequency = period that is purely Type C congestion. Notice the relatively flat spectrum 
with suppressed peaks at the bandwidth mismatches and emergence of broad peaks at large 
periods. Packet loss is approximately 15 percent. Figure 7 illustrates the conditions for 
network 28 for which this plot was obtained. 

[0041] As discussed above, the monitoring process can be performed upstream or 
downstream of the congestion. In either case, the monitor node 26 (see Figure 1), which 
may also be used as a control node when configured to implement a congestion control 
process, may be configured to collect a data sample of the monitored stream (say, for 
example, between 20 seconds and one minute worth of data) and then perform a Fast Fourier 
Transform (FFT) to obtain the power spectrum of that data. Any resulting peaks in the power 
spectrum can be determined (for example, by measuring their amplitude with respect to the 
mean) and if the peaks are well defined (say, by a measure of their sharpness in amplitude 



Attorney's Docket No.:003997.P008 



- 16- 



Application 



over the one-half power point or other convenient measure) and a statistically significant 
amount of packet loss is being experienced, this may be taken as a sign that the congestion is 
self-induced. If no well-defined peaks are founds, but the data shows that there is a 
statistically significant amount of packet loss, this may be taken as an indication that the 
congestion is cross-induced. 

[0042] Thus a scheme for categorizing congestion in a communication network has been 
described. This process may be used to determine which, if any, congestion control 
techniques should be applied in a network. For example, in one embodiment, the control 
technique described in the above-cited co-pending patent application, Application No. 
09/539,434, which is hereby incorporated by reference in its entirety, may be used. Under the 
scheme described in the co-pending patent application, the end-to-end packet losses of one or 
more traffic streams transmitted across a congested network may be reduced by modulating 
the bandwidths (i.e., the inter-packet delay) of the corresponding traffic streams applied to the 
node(s) of the network from one or more control points along the network topology. This 
reduction in packet loss results in a reduction in fluctuations or variability of the controlled 
traffic streams, an increase in bandwidth utilization of a congested link at downstream points 
and a reduction in times to transmit files (e.g., to an end-user). The control points can be 
either upstream or downstream of one or more congestion points along the network. 
[0043] By modulating the bandwidth of the traffic streams, feedback to the packet origin 
points (e.g., origin servers) congestion avoidance processes or algorithms is provided via 
acknowledgement delays from the ultimate client. That is, the time at which such 
acknowledgements are received at these servers is increased. This feedback indirectly (i.e., 
through existing congestion avoidance processes present in packet networks) controls the rate 
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at which the server transmits new packets into the network in such a way that overall packet 
loss is minimized. 

[0044] Thus, this scheme introduces feedback control upstream or downstream of a 
congested node (such as a router or switch) to reduce packet loss and thereby smooth traffic 
flow and provide for increased throughput through that node (and even other downstream 
nodes). The feedback may be applied using a separate control node upstream or downstream 
of the congested node, or the feedback mechanisms may be integrated into existing network 
nodes. The feedback may be applied at frequencies (i.e., time intervals) that depend on the 
characteristics of the network traffic media (e.g., the bandwidth of the communication links). 
For example, the control bandwidth node (i.e., the inter-packet spacing for transmission from 
the control node) may be set at bandwidths that correspond to the peaks identified in the 
power spectrums of the sampled data. By applying such feedback control, the packet loss 
across multiple congested nodes is reduced, resulting in higher network throughput. Not only 
is throughput improved for the node immediately downstream of the point of feedback 
control, it may also be improved for subsequent downstream nodes. 

[0045] One potential application of the above-described process may be "fingerprinting" 
sources of congestion in a network. It is possible that individual congestion sources will 
have unique FFT signatures (i.e., unique peaks at certain periods). Thus, when a connection 
or traffic stream experiences congestion, diagnostic equipment (e.g., at a monitor node, 
which could be added temporarily to a network) could be used to obtain a power spectrum of 
the stream and then the resulting spectrum could be analyzed against a database of known 
congestion sources much like the way human fingerprints are analyzed. A match in power 
spectrums could thereby yield the actual source (or sources) of congestion for the traffic 
stream of interest and corrective action taken accordingly. It should be remembered that 
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although the foregoing description and accompanying figures discuss and illustrate specific 
embodiments, the broader scope of present invention should be measured only in terms of the 
claims that follow. 
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